home *** CD-ROM | disk | FTP | other *** search
/ Meeting Pearls 1 / Meeting Pearls Vol 1 (1994).iso / installed_progs / text / faqs / compilers-faq < prev    next >
Encoding:
Internet Message Format  |  1994-05-02  |  22.2 KB

  1. Subject: comp.compilers monthly message and Frequently Asked Questions
  2. Newsgroups: comp.compilers,news.answers,comp.answers
  3. From: compilers-request@iecc.com (John R. Levine)
  4. Date: Sun, 1 May 1994 11:00:03 GMT
  5.  
  6. Archive-name: compilers-faq
  7.  
  8. This is the comp.compilers monthly message, last edited May 1994.
  9.  
  10. Contents:
  11.  
  12. -- What is comp.compilers?
  13. -- How do I receive it?
  14. -- How do I submit a message?
  15. -- What happens to submitted messages?
  16. -- How do I respond to the author of a message?
  17. -- How do I contact the moderator?
  18. -- Are back issues available?
  19.  
  20. -- Some Frequently Asked Questions:
  21.  
  22. * Where can I get a C or C++ grammar in yacc?
  23. * Where can I get the Gnu C compiler?
  24. * Are there other free C compilers?
  25. * Where can I get a Fortran grammar in yacc or a Fortran compiler?
  26. * Where can I get Modula-2, Pascal, Ada, or SQL grammars in yacc?
  27. * Where can I get a Cobol grammar in yacc?
  28. * Where can I get a Basic grammar in yacc?
  29. * Where can I get a PL/M grammar?
  30. * Are there free versions of yacc and lex ?
  31. * Are there versions of yacc and lex for MS-DOS?
  32. * What other compilers and tools are freely available?
  33. * How can I get started with yacc and lex and compiler writing in general?
  34. * Where I can I FTP the sources to the programs in Holub's "Compiler
  35.   Design in C" or Mak's "Writing Compilers and Interpreters" ?
  36.  
  37. -- What is comp.compilers?
  38.  
  39. It is a moderated usenet news group addressing the topics of compilers in
  40. particular and programming language design and implementation in general.
  41. It started in 1986 as a moderated mailing list, but interest quickly grew to
  42. the point where it was promoted to a news group.  Recent topics have
  43. included optimization techniques, language design issues, announcements of
  44. new compiler tools, and book reviews.
  45.  
  46. Messages come from a wide variety of people ranging from undergraduate
  47. students to well-known experts in industry and academia.  Authors live all
  48. over the world -- there are regular messages from the U.S, Canada, Europe,
  49. Australia, and Japan, with occasional ones from as far away as Malaysia.  I
  50. have no idea how large the readership is, since the anarchic nature of
  51. usenet makes it impossible to tell who reads it, but I believe that the total
  52. is in the tens of thousands.
  53.  
  54. Unless there is specific language to the contrary, each message represents
  55. only the personal opinion of its author.  I claim no compilation copyright on
  56. comp.compilers.  As far as I am concerned, anyone can reproduce any message
  57. for any purpose.  Individual authors may retain rights to their messages,
  58. although I will not knowingly post anything that does not permit unlimited
  59. distribution in any form.  If you find comp.compilers useful in writing a
  60. book, producing a product, etc., I would appreciate an acknowledgement of
  61. usenet and comp.compilers.
  62.  
  63. -- How do I receive it?
  64.  
  65. The easiest way is to read comp.compilers on a system that gets usenet news.
  66.  
  67. If you don't have access to usenet news, it's also available via E-mail via
  68. a LISTSERV forwarder at the American University.  To subscribe a person
  69. should send e-mail to listserv@american.edu with one line in the mail
  70. message (not in the subject!)  That line should read:
  71.  
  72.                         SUBSCRIBE COMPIL-L full_name
  73. for example:
  74.                         SUBSCRIBE COMPIL-L Ima Hacker
  75.  
  76. To get off the list the subscriber should send e-mail to the same address
  77. with the message:       SIGNOFF COMPIL-L
  78.  
  79. If you have problems getting on or off the list, please contact me.  In
  80. particular, if you want to use an address other than your own personal mail
  81. address, you have to ask me to set it up.  If I receive bounce messages for
  82. an address on the mailing list for two days in a row, I delete it.  If this
  83. happens to you and your address subsequently becomes reachable again, you
  84. can resubscribe.
  85.  
  86. -- How do I submit a message?
  87.  
  88. Mail it to compilers@iecc.com, also known as compilers@iecc.uucp or
  89. iecc!compilers.  I review messages nearly every day, usually including
  90. weekends, and most messages are posted to the net within a day after I
  91. receive them.  Occasionally when I go on vacation there may be up to a
  92. week's delay, though I try to send out a message when that will happen.
  93.  
  94. Most net news systems will automatically turn posted messages into mail to
  95. compilers, but some, particularly systems running notes, don't do that
  96. correctly.  As a result, I sometimes receive hundreds of copies of a
  97. message, all mangled slightly differently.  Please mail your contributions
  98. unless you're sure your posting software works correctly.
  99.  
  100. When you send a message to compilers, I understand that to mean that you
  101. want me to post it to usenet, which means it will be sent to tens of
  102. thousands of potential readers at thousands of computers all around the
  103. world.  It may also appear in a printed comp.compilers annual and other
  104. books, in the ACM SIGPLAN Notices, in on-line and off-line archives,
  105. CD-ROMs, and anywhere else that some reader decides to use it.
  106.  
  107. If you don't want me to post something, send it instead to
  108. compilers-request.  (See below.)
  109.  
  110. PLEASE: Format messages with lines of less than 80 characters, since many
  111. news readers (including mine) don't auto-wrap very well.  Also remove quoted
  112. material not immediately germane to your response.  Messages must be in plain
  113. ASCII, not TeX input, troff, SGML, RTF or any other markup language.
  114.  
  115. -- What happens to submitted messages?
  116.  
  117. Barring mail problems, they arrive in a special mailbox here at iecc.  I
  118. then edit the headers, trim down quoted text, fix typos and grammatical
  119. errors, remove cute signatures, and then post them to usenet.  If I think a
  120. message needs more editing than that, I return it to the author for
  121. rewriting.  The main reasons I return a message are that it appears more
  122. appropriate for another group, the message is too garbled to fix, it
  123. contains too much quoted material relative to the amount of new material, or
  124. I don't understand it.  I also usually return messages that directly attack
  125. individuals, since the net has plenty of other places for ad-hominem battles.
  126. Another possibility is that a message doesn't have a valid return e-mail
  127. address.  If your mail system insists on putting a bogus address in the From:
  128. line, be sure that you put a usable address in your signature.
  129.  
  130. If a message asks a simple question I sometimes answer it myself rather than
  131. posting it.  When two or three messages arrive with the same answer to a
  132. question, I usually post only one of them, with a comment crediting the
  133. others.
  134.  
  135. If you send in a message and don't either see it posted or receive
  136. something back in a few days, it probably got lost in the mail and you
  137. should contact me, preferably via a different mail route.  I post or
  138. respond to all messages except for ones that appear to have been sent by
  139. mistake, e.g. no contents, contents consisting only of another quoted
  140. message, or a personal message for the author of a previous message.
  141. Sometimes when I'm feeling exasperated I disregard messages that re-ask
  142. one of the frequently asked questions that are answered below.
  143.  
  144. One of the most time-consuming jobs in moderating the group is trimming down
  145. the quotes in followup articles.  In most cases, you can expect readers to
  146. have seen the previous article, so only a few lines of quoted text should be
  147. needed to remind the reader of the context.
  148.  
  149. I have installed a simple-minded quote filter that mechanically returns to
  150. the sender any message that contains more quoted than unquoted lines.  Please
  151. edit your quotes before you send in a response, to avoid having the filter
  152. bounce your message.  Since the quote filter is pretty dumb, I do look at
  153. bounced messages myself.  If the filter bounces a message of yours by mistake,
  154. don't panic -- it'll get posted anyway.
  155.  
  156. ``Help wanted'' and ``Position Available'' messages are collected each week
  157. and posted in a digest every Sunday.
  158.  
  159. -- How do I respond to the author of a message?
  160.  
  161. I try to be sure that every message contains valid From: and Reply-To:
  162. headers.  The automatic "reply" commands in most news readers let you send
  163. mail to the author.  If you're replying to a message in a digest, be sure
  164. to respond to the author of the particular message, not to the pseudo-author
  165. of the digest.
  166.  
  167. Some obsolete news readers attempt to reply using the Path: header, but for
  168. technical reasons the Path: header in a moderated message cannot point to
  169. the actual author.  In fact, the Path: header in a compilers message is
  170. deliberately a bad mail address, so if you have such a news reader you'll
  171. have to edit the addresses in responses yourself and, I hope, encourage your
  172. system manager to update your news and mail software.
  173.  
  174. Sometimes mail to an author bounces, either because a gateway isn't
  175. working or because the return address is unregistered or otherwise bad.
  176. Please don't ask me to forward it, since my machine is no better connected
  177. than anyone else's.  (It's just another node on the Internet.)  If
  178. you send me a message obviously intended for the author of an item, I will
  179. discard it on the theory that if it wasn't important enough for you to
  180. send it to the right place, it isn't important enough for me, either.
  181.  
  182. -- How do I contact the moderator?
  183.  
  184. Send me mail at compilers-request@iecc.com.  I treat messages to
  185. compilers-request as private messages to me unless they state that they
  186. are for publication.
  187.  
  188. -- Are back issues available?
  189.  
  190. I have complete archives going back to the original mailing list in 1986.
  191. The archives now fill about 18 megabytes, and are growing at over 200K per
  192. month.  I update the archives at the end of each month.  People with ftp
  193. access can get them from primost.cs.wisc.edu, (128.105.36.61) where James
  194. Larus has kindly provided space, in directory pub/comp.compilers.  The
  195. archives contain a compressed Unix mailbox format file for each month,
  196. with names like 91-08.Z.  The file INDEX.Z lists all of the subject lines
  197. for every message in the archives, and in most cases is the first file you
  198. should retrieve.  I am in the process of moving the archives to iecc.com
  199. (140.186.81.1).  The network software there is buggy, so although FTP works,
  200. it can be excruciatingly slow.  At iecc.com, everything is compressed with
  201. gzip rather than compress.
  202.  
  203. The archives are available via modem from Channel One, an excellent local
  204. BBS.  You have to register, but no payment is needed to download the
  205. archives which are in Area 6.  (If you call more than once or twice, it
  206. would be nice to sign up for at least the $25 trial membership.)  The 2400
  207. BPS telephone number is +1 617 354 8873, and the Telebit number is +1 617
  208. 354 0470.  There is a ZIP format archive per month with names like
  209. comp9108.zip, with the most recent archive also containing the index.
  210.  
  211. There is now a mail server at compilers-server@iecc.com that can mail you
  212. indexes, messages, and the files mentioned below.  Send it a message
  213. containing "help" to get started.
  214.  
  215. I have also published a printed edition of the 1990 messages grouped by
  216. thread and topic, and with some indexes, and may publish subsequent editions.
  217. (If you'd be intereted in editing the 1991, 1992, or later books, let me
  218. know.)  see the message which should immediately follow this one for further
  219. details on the 1990 book. 
  220.  
  221. -- Some Frequently Asked Questions:
  222.  
  223. NOTE: Many issues are discussed occasionally on comp.compilers, but not
  224. frequently enought to make the FAQ sheet.  If you have a question but the
  225. answer isn't in the FAQ, you may well be able to get good background by
  226. reading the appropriate articles in the archive.  If you can FTP, please
  227. at least get the index and look through it.
  228.  
  229. The various files that I mention below that I have are in the compilers
  230. archive at primost.cs.wisc.edu, and are also available from the mail
  231. server mentioned above.  If you can FTP them, please do so rather than
  232. using the mail server, since the mail bandwith is quite small.
  233.  
  234. * Where can I get a C or C++ grammar in yacc?
  235.  
  236. Jim Roskind's well-known C and C++ grammars are in the archive, as is
  237. a C grammar written by Jeff Lee.  Dave Jones posted a parser as
  238. message 91-09-030.  Another C grammar was posted to comp.sources.misc
  239. in June 1990, v13 i52, archive name ansi-c_su.  GCC and G++ are based
  240. on yacc grammars, see below.
  241.  
  242. * Where can I get the Gnu C compiler?
  243.  
  244. GCC is a high-quality free C and C++ compiler.  (Free is not the same as
  245. public domain, see the GCC distribution for details.)  It is available in
  246. source from prep.ai.mit.edu.  You need an existing C compiler and
  247. libraries to bootstrap it.
  248.  
  249. A development system called "djgpp" by DJ Delorie <dj@ctron.com> is based
  250. on gcc and other GNU programs, and runs on 386 or higher PCs running
  251. MS-DOS.  This is available by FTP from the SimTel archives (primary mirror
  252. is oak.oakland.edu) in the directory pub/msdos/djgpp.
  253.  
  254. * Are there other free C compilers?
  255.  
  256. The lcc compiler, written by people at Princeton and Bell Labs, is
  257. available via FTP from princeton.edu.  It is supposed to generate code
  258. nearly as good as GCC while being considerably faster and smaller.  It
  259. comes with a demonstration VAX code generator and documentation on the
  260. code generation interfaces.  Production code generators for the VAX, MIPS,
  261. and Motorola 68020 are available for research use to universities willing
  262. to execute a license agreement; the FTP package elaborates.  Lcc uses a
  263. hard-coded C parser because it's faster than yacc.
  264.  
  265. * Where can I get a Fortran grammar in yacc or a Fortran compiler?
  266.  
  267. I have a small subset parser in the archive mentioned above.  The F2C
  268. Fortran to C translator is a respectable Fortran system (so long as
  269. you have a C compiler to compile its output and its libraries) and
  270. contains a full F77 parser and is available in source form via FTP
  271. from research.att.com and by mail from netlib@research.att.com.
  272.  
  273. * Where can I get Modula-2, Pascal, Ada, or SQL grammars in yacc?
  274.  
  275. I have one each of those, too, in the archive mentioned above, though I
  276. haven't tried to use any of them.
  277.  
  278. * Where can I get a Cobol grammar in yacc?
  279.  
  280. Nowhere for free, as far as I can tell.  This question is asked every few
  281. months and there has never, ever, been any positive response. Perhaps some
  282. of the interested people could get together and write one.  The commercial
  283. PCYACC from Abraxas (see below) comes with a bunch of sample grammars
  284. including one for Cobol-85.
  285.  
  286. Also see the Cobol FAQ posted monthly to comp.lang.misc and alt.cobol.
  287.  
  288. * Where can I get a Basic grammar in yacc?
  289.  
  290. Take a look at ftp.uu.net:comp.sources.unix/volume2/basic which contains
  291. a Basic interpreter with yacc parser.
  292.  
  293. * Where can I get a PL/M grammar?
  294.  
  295. There's one in the archives, called plm.shar.  Also see message
  296. 94-03-062 for a report on a PL/M to C translator.
  297.  
  298. * Are there free versions of yacc and lex ?
  299.  
  300. Vern Paxton's flex is a superior reimplementation of lex.  It is available
  301. from the same places as Gnu sources.  Berkeley Yacc is a quite compatible
  302. PD version of yacc by Bob Corbett, available as ~ftp/pub/byacc.tar.Z on
  303. okeeffe.berkeley.edu.  Gnu Bison is derived from an earlier version of
  304. Corbett's work and is also fairly compatible with yacc.  A byacc extension
  305. that displays graphically the progress of a parse can be found in Jim
  306. Roskind's C++ grammar in the FTP compilers archive.  (The files are too
  307. big for the mail archive, sorry.)
  308.  
  309. * Are there versions of yacc and lex for MS-DOS?
  310.  
  311. There are several of them.  Commercial versions are MKS lex&yacc from MKS
  312. in Waterloo Ont., +1 519 884 2251 or inquiry@mks.com, and PCYACC from
  313. Abraxas Software in Portland OR, +1 503 244 5253.  Both include both yacc
  314. and lex along with a lot of sample code.
  315.  
  316. The standard flex source compiles under the usual DOS compilers, although
  317. you may want to make some of the buffers smaller.  A DOS version of Bison
  318. is on wuarchive.wustl.edu [128.252.135.4] and other servers under
  319. /mirrors/msdos/txtutl/bison111.zip. See message 92-07-012 for more info.
  320.  
  321. * What other compilers and tools are freely available?
  322.  
  323. There is a three-part FAQ posting in comp.compilers and other groups
  324. listing compiler tools freely available in source form, maintained by
  325. Steve Robenalt <free-compilers@idiom.berkeley.ca.us>.  It is posted monthly,
  326. right after this message.  If it's not on your system, you can FTP it from
  327. rtfm.mit.edu in the directory /pub/usenet/news.answers/free-compilers, or
  328. via mail by sending a message to to mail-server@rtfm.mit.edu with the
  329. command "send usenet/news.answers/free-compilers/*" in the text.
  330.  
  331. * How can I get started with yacc and lex and compiler writing in general?
  332.  
  333. By reading any of the many books on the topic.  Here are a few of them.
  334. Also see message 93-01-155 which reviews many compiler textbooks.
  335.  
  336. Aho, Sethi, and Ullman, "Compilers: Principles, Techniques, and Tools,"
  337. Addison Wesley, 1986, ISBN 0-201-10088-6, the "dragon book".  Describes
  338. clearly and completely lexing and parsing techniques including the ones in
  339. yacc and lex.  The authors work or have worked at Bell Labs with Steve
  340. Johnson and Mike Lesk, the authors of Yacc and Lex.
  341.  
  342. Alan Holub, "Compiler Design in C," Prentice-Hall, 1990, ISBN
  343. 0-13-155045-4.  A large book containing the complete source code to a
  344. reimplementation of yacc and lex and a C compiler.  Quite well written,
  345. too, though it has a lot of errors.  The fourth printing is supposed to
  346. correct most of them.  An errata list is in message 90-06-081.
  347.  
  348. John R. Levine, Tony Mason, and Doug Brown, ``Lex & Yacc,'' 2nd Edition,
  349. O'Reilly and Associates, 1992, ISBN 1-56592-000-7, $29.95.  A concise
  350. introduction with completely worked out examples and an extensive
  351. reference section.  The new edition is completely revised from the earlier
  352. 1990 edition.
  353.  
  354. Donnely and Stallman, "The Bison Manual," part of the on-line distrubution
  355. of the FSF's Bison, a reimplementation of yacc.  As with everything else from
  356. the FSF, full source code is included.
  357.  
  358. Axel T. Schreiner and H. George Friedman, Jr., "Introduction to Compiler
  359. Construction with UNIX," Prentice-Hall, 1985.  Oriented to tutorial work.
  360. Good for beginners.  Develops a small subset-of-C compiler through the book.
  361. (Recommended by Eric Hughes <hughes@ocf.Berkeley.EDU>.)  Richard Hash
  362. <rgh@shell.com> comments that the book has many typographical errors, and
  363. readers should be suspicious of the examples until they actually try them.
  364. Richard Y. Kim <richard@ear.mit.edu> reports that sources are available for
  365. FTP as a.cs.uiuc.edu:pub/friedman/tar.
  366.  
  367. Bennett, J.P. "Introduction to Compiling Techniques - A First Course Using
  368. Ansi C, Lex and Yacc," McGraw Hill Book Co, 1990, ISBN 0-07-707215-4.
  369. It's intended for a first course in modern compiler techniques, is very
  370. clearly written, and has a full chapter on YACC.  I found it to be a good
  371. introductory text before getting into the 'Dragon book'.  (Recommended by
  372. John Merlin <J.H.Merlin@ecs.southampton.ac.uk>.)  Source code is available
  373. at ftp.bath.ac.uk.
  374.  
  375. Charles N. Fischer & Richard J. LeBlanc, "Crafting A Compiler", Benjamin
  376. Cummings Publishing, Menlo Park, CA, 1988, ISBN 0-8053-3201-4.  There's
  377. also a revised version as of 1990 or 1991 titled "Crafting A Compiler in
  378. C", with all examples in C (the original used ADA/CS).  Erich Nahum
  379. <nahum@cs.umass.edu> writes: A key compiler reference.  We used the
  380. original to great effect in Eliot Moss' graduate compiler construction
  381. class here at UMass.  My feeling is that Fischer & LeBlanc is a good
  382. tutorial, and one should use Aho, Sethi, & Ullman as a reference.
  383.  
  384. Des Watson, "High-Level Languages and Their Compilers," International
  385. Computer Science Series, Addison-Wesley Publishing Company, Wokingham
  386. England, 1989.  Adrian Howard <adrianh@cogs.sussex.ac.uk> writes: This is
  387. the kindest, most readable introduction to compilers at the graduate level
  388. I have ever read - an excellent example of what textbooks should all be
  389. like.
  390.  
  391. W.M. Waite and G. Goos, "Compiler Construction," Springer-Verlag, New
  392. York, 1984.  Dick Grune <dick@cs.vu.nl> writes: A theoretical approach to
  393. compiler construction. Refreshing in that it gives a completely new view
  394. of many subjects. Heavy reading, high information density.
  395.  
  396. J.P. Tremblay and P.G. Sorenson, "The Theory and Practice of Compiler
  397. Writing," McGraw-Hill, 1985.  Dick Grune <dick@cs.vu.nl> writes: Extensive
  398. and detailed. Heavy reading. To be consulted when other sources fail.
  399.  
  400. James E. Hendrix, "The Small-C Compiler", 2nd ed., M&T Books, ISBN
  401. 0-934375-88-7 <Book Alone>, 1-55851-007-9 <MS-DOS Disk>,
  402. 0-934375-97-6 <Book AND Disk>.
  403.  
  404. William Jhun <ec_ind03@oswego.edu> writes: It explaines the C-language is
  405. thorough....and explains every single aspect of the compiler. The book
  406. compares source code to p-code to assembly. It goes over a nice set of
  407. optimization routines, explains the parser, the back end, and even
  408. includes source code, which the compiler on the disk can actually compile
  409. itself. It's an extremely interesting book, check it out.
  410.  
  411. Ronald Mak, "Writing Compilers and Interpreters: An Applied Approach",
  412. 1991, John Wiley and Sons, Inc. ISBN 0-471-50968-X.
  413.  
  414. Andrew Tucker <a_tucker@paul.spu.edu> writes: This 512-page book presents
  415. a strictly hands on approach, developing a Pascal interpreter and
  416. interactive debugger, then completing with a compiler which emits 8086
  417. assembly.  All source code is provided in print and on disk.  This book is
  418. very low to non-existent in theoretical content, but is very practical and
  419. readable for an introduction.  Taylor Hutt <thutt@access.digex.net>
  420. comments that the book is a piece of junk.  The code that is contained in
  421. the book is full of bugs, and the code that it generates will not work.
  422.  
  423. "The Art of Compiler Design", Thomas Pittman & James Peters, Prentice-Hall
  424. International, 1992, Englewood Cliffs, NJ 07632, 0-13-046160-1
  425.  
  426. Franklin L. Vermeulen <vfrank@vnet3.vub.ac.be> writes: This is a very
  427. nicely written and straightforward text on compiler construction.  There
  428. is a certain (unavoidable?) amount of overlap with a course on automata
  429. (as in Aho, Sethi and Ullman).  It is based on Modula-2 and on an
  430. experimental tool, the TAG compiler-compiler (Transformational Attribute
  431. Grammar) which seems to be a C-independent superset of lex/yacc, because
  432. its syntax allows you to specify all semantic actions without a single
  433. line of C-code (or any other implementation language, for that matter).
  434.  
  435. If anyone sends in others, I'll be happy to add them to the list.
  436.  
  437. * Where I can I FTP the sources to the programs in Holub's "Compiler
  438. Design in C" or Mak's "Writing Compilers and Interpreters" ?
  439.  
  440. You can't.  In each book there's ordering information for diskettes with
  441. the code.
  442.  
  443. Regards,
  444. John Levine, comp.compilers moderator
  445. -- 
  446. Send compilers articles to compilers@iecc.com or
  447. {ima | spdcc | world}!iecc!compilers. Meta-mail to compilers-request@iecc.com.
  448.  
  449.